<?php

/**
 * Este es la clase modelo de la tabla "inasistencia".
 *
 * Los siguientes campos estan disponibles en la tabla 'inasistencia':
 * @property integer $idinasistencia
 * @property string $estado
 * @property string $fecha
 * @property integer $alumno_idalumno
 *
 * Las siguientes son las relaciones disponible del modelo:
 * @property Alumno $alumnoIdalumno
 */
class Inasistencia extends CActiveRecord
{
	public $alumno_user_nombres;
	public $alumno_user_apellido_paterno;
	public $alumno_user_apellido_materno;
	public $alumno_user_run;
	public $alumno_curso_nombre;
	public $alumno_curso_nivel;
	public $alumno_curso_letra;
	public $estados=array('Ausente'=>'Ausente','Atrasado'=>'Atrasado','Justificado'=>'Justificado');
	/**
	 * Returns the static model of the specified AR class.
	 * @return Inasistencia the static model class
	 */
	public static function model($className=__CLASS__)
	{
		return parent::model($className);
	}

	/**
	 * @return string the associated database table name
	 */
	public function tableName()
	{
		return 'inasistencia';
	}

	/**
	 * @return array validation rules for model attributes.
	 */
	public function rules()
	{
		// NOTE: you should only define rules for those attributes that
		// will receive user inputs.
		return array(
			array('alumno_idalumno', 'required'),
			array('alumno_idalumno', 'numerical', 'integerOnly'=>true),
			array('estado', 'length', 'max'=>45),
			array('fecha', 'safe'),
			// The following rule is used by search().
			// Please remove those attributes that should not be searched.
			array('idinasistencia, estado, fecha, alumno_user_nombres,alumno_user_apellido_paterno,alumno_user_apellido_materno,alumno_user_run,alumno_curso_nombre,alumno_curso_nivel,alumno_curso_letra', 'safe', 'on'=>'search'),
		);
	}

	/**
	 * @return array relational rules.
	 */
	public function relations()
	{
		// NOTE: you may need to adjust the relation name and the related
		// class name for the relations automatically generated below.
		return array(
			'alumno' => array(self::BELONGS_TO, 'Alumno', 'alumno_idalumno'),
		);
	}

	/**
	 * @return array customized attribute labels (name=>label)
	 */
	public function attributeLabels()
	{
		return array(
			'idinasistencia' => 'Idinasistencia',
			'estado' => 'Estado',
			'fecha' => 'Fecha',
			'alumno_idalumno' => 'Alumno',
			'alumno_user_nombres'=>'Nombres',
			'alumno_user_apellido_paterno'=>'Apellido Paterno',
			'alumno_user_apellido_materno'=>'Apellido Materno',
			'alumno_user_run'=>'RUN',
			'alumno_curso_nombre'=>'Nombre Curso',
			'alumno_curso_nivel'=>'Nivel',
			'alumno_curso_letra'=>'Letra',
		);
	}

	/**
	 * Devuelve una lista de modelos basado en la b�squeda o filtro acutal.
	 * @return CActiveDataProvider the data provider that can return the models based on the search/filter conditions.
	 */
	public function search()
	{
		// Warning: Please modify the following code to remove attributes that
		// should not be searched.

		$criteria=new CDbCriteria;

		$criteria->compare('idinasistencia',$this->idinasistencia);
		$criteria->with=array('alumno','alumno.user',array('condition'=>array('activo=1')),'alumno.curso');
		$criteria->compare('estado',$this->estado,true);
		$criteria->compare('fecha',$this->fecha,true);
		$criteria->compare('user.nombres',$this->alumno_user_nombres);
		$criteria->compare('user.apellido_paterno',$this->alumno_user_apellido_paterno);
		$criteria->compare('user.apellido_materno',$this->alumno_user_apellido_materno);
		$criteria->compare('curso.nombre',$this->alumno_curso_nombre);
		$criteria->compare('curso.nivel',$this->alumno_curso_nivel);
		$criteria->compare('curso.letra',$this->alumno_curso_letra);
		$criteria->compare('user.run',$this->alumno_user_run);

		return new CActiveDataProvider($this, array(
			'criteria'=>$criteria,
		'sort'=>array(
								'attributes'=>array(
									'alumno_user_nombres'=>array(
										'asc'=>'user.nombres',
										'desc'=>'user.nombres DESC',
		),
									'alumno_user_apellido_paterno'=>array(
										'asc'=>'user.apellido_paterno',
										'desc'=>'user.apellido_paterno DESC',
		),
									'alumno_user_apellido_materno'=>array(
										'asc'=>'user.apellido_materno',
										'desc'=>'user.apellido_materno DESC',
		),
									'alumno_user_run'=>array(
										'asc'=>'user.run',
										'desc'=>'user.run DESC',
		),
									'alumno_curso_nombre'=>array(
										'asc'=>'curso.nombre',
										'desc'=>'curso.nombre DESC',
		),
									'alumno_curso_nivel'=>array(
												'asc'=>'curso.nivel',
												'desc'=>'curso.nivel DESC',
		),
									'alumno_curso_letra'=>array(
														'asc'=>'curso.letra',
														'desc'=>'curso.letra DESC',
		),
									'*',
		),
		),
		));
	}
}